草庐IT

python - 在类定义之外定义一个方法?

全部标签

ruby - Require 返回一个数组而不是一个 bool 值

根据Kernel#require的文档该方法返回一个bool值。然而,我在IRBsession中注意到对于某些文件require返回一个数组。ruby-1.8.7-p330:001>require'net/http'=>trueruby-1.8.7-p330:002>require'date'=>trueruby-1.8.7-p330:003>require'lib/data_provider'=>["DataProviders"]返回的数组包含在data_provider.rb中定义的模块的名称:moduleDataProvidersmoduleCachedclassFoo#...e

ruby - 是否可以阻止 Jekyll 为每个帖子生成一个页面

我将Jekyll用于博客/作品集网站。我有几篇文章是投资组合条目,还有几篇是博客条目。我可以使用投资组合条目帖子来构建投资组合页面(www.alexmarchant.com/portfolio),但Jekyll仍会为每个投资组合条目生成一个永久链接的单独页面。有什么办法可以关闭它吗?我在帖子的YAML前端部分尝试了以下内容:固定链接:无永久链接:错误都不行。 最佳答案 我找到了一个黑客来做你想做的事:当你将永久链接设置为一个已经存在的页面时,它就不会生成(原始页面会在那里),但它在Jekyll中仍然可以作为帖子/页面实体使用。因此,

ruby - 如何将方法或 lambda 转换为非 lambda proc

如下面的ruby​​示例所示,我无法调用参数数量错误的lambda作为从Method创建的Proc因为它对参数的数量很严格:#methodwithnoargsdefa;endinstance_eval(&method(:a))#ArgumentError:wrongnumberofarguments(1for0)method(:a).to_proc.call(1,2,3)#ArgumentError:wrongnumberofarguments(3for0)method(:a).to_proc.lambda?#=>true如何从Proc或Method中获取不是lambda的Proc?

ruby-on-rails - 如果只有一个存在,是否有用于返回第一个数组元素的 ruby​​ 习惯用法?

如果数组只包含一个值,我想返回数组的第一个元素。目前,我使用:vals.one??vals.first:vals.presence因此:vals=[];vals.one??vals.first:vals.presence#=>nilvals=[2];vals.one??vals.first:vals.presence#=>2vals=[2,'Z'];vals.one??vals.first:vals.presence#=>[2,"Z"]是否有内置的东西可以做到这一点,或者是否有更好的设计考虑?我的用例是特定的,涉及知道从方法(将实现上述代码)中期望什么的演示者。如果这些演示者将所有返回

ruby - 为什么带有 splat 参数的 Ruby 过程/ block 的行为与方法和 lambda 不同?

为什么带有splat参数的Ruby(2.0)过程/block的行为与方法和lambda不同?deffoo(ids,*args)pidsendfoo([1,2,3])#=>[1,2,3]bar=lambdado|ids,*args|pidsendbar.call([1,2,3])#=>[1,2,3]baz=procdo|ids,*args|pidsendbaz.call([1,2,3])#=>1defqux(ids,*args)yieldids,*argsendqux([1,2,3]){|ids,*args|pids}#=>1这是对此行为的确认,但没有解释:http://makandra

ruby - ActionDispatch::IntegrationTest 中的 stub 方法

我正在做一些条纹集成测试,我想stub/模拟一些端点。我正在尝试这样做:Stripe::Charge.stubs(:retrieve).returns({:balance_transaction=>40})但我得到以下信息:NoMethodError:undefinedmethod`stubs'forStripe::Charge:Classstub的正确语法是什么?Rails4、Ruby2。编辑:这是我的完整测试方法。本质上,我的payment_succeededwebhook命中strip以检索费用及其相关的余额交易以记录交易费用。我正在使用stripe_mock来模拟webhook

ruby-on-rails - 如何在递归方法中使用预加载集合

我有以下自指关联:classAction我的问题是should_finish和should_start正在互相调用,即使我预加载了父级,它仍然会导致许多查询:Action.includes(:parents).last.should_finish#anewqueryeverytimeitchecksforparents关于如何缓存actions和parents有什么想法吗?编辑-让我提供一些背景信息:#actionstable:actions_parentstable:#id|durationtask_id|parent_id#1|52|1#2|103|1#3|204|2#4|154|

ruby - 使用 Sinatra 和 rspec stub Controller 方法

因此,我正在尝试找出一种在rspec中为Sinatra应用stubController方法的方法。这样做的主要原因是测试应用程序的逻辑流程,并确保它在满足某些条件时调用必要的功能。所以,本质上,我希望能够做类似的事情controller.should_receive(:fancy_method).and_return("Thisisastring")我遇到的困难是访问sinatra应用程序中的Controller实例。我可以使用sinatraController类上的class_eval覆盖当前函数,但我想断言这些函数确实在运行。有人有什么建议吗?谢谢。 最

ruby - 在 Ruby 中解析大文件的最快方法

我有一个大约150MB的简单文本文件。我的代码将读取每一行,如果它与某些正则表达式匹配,它就会写入输出文件。但是现在,遍历文件的所有行(几分钟)只需要很长时间,就像File.open(filename).eachdo|line|#dosomestuffend我知道循环遍历文件行需要一段时间,因为即使我对“#dosomestuff”中的数据不做任何操作,它仍然需要很长时间。我知道一些unix程序几乎可以立即解析这样的大文件(比如grep),所以我想知道为什么ruby​​(MRI1.9)读取文件需要这么长时间,有什么方法可以让它更快吗? 最佳答案

ruby-on-rails - 在 Ruby 中运行 eval 有安全的方法吗?

我们正在开发一种与Tropo具有类似要求的产品(参见https://github.com/tropo/tropo-samples/tree/master/ruby),允许用户编写一个ruby​​脚本,该脚本可以访问传入的一些函数和变量。但是,我们希望避免用户访问全局调用删除所有用户或终止程序。有没有办法用eval来完成这个? 最佳答案 这在很大程度上取决于您如何实现它,但请研究绑定(bind)与eval的使用。通过创建您自己的绑定(bind)并使用“安全”对象预加载它,您可以限制用户可以使用他的代码执行的操作。http://rdoc